# **Designing with the IP Integrator Demo Script**

#### Introduction

This demonstration introduces the IP integrator (IPI) feature available in the Vivado® Design Suite.

## **Preparation:**

 Required files: \$TRAINING\_PATH/IP\_Integrator/demo/KCU105/ verilog

• Required hardware: None

## **Designing with the IP Integrator**

| Action with Description |                                                                                                       | Point of Emphasis and Key Takeaway                                                                                                                                |  |
|-------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| •                       | Launch Vivado Design Suite 2021.2.                                                                    |                                                                                                                                                                   |  |
| •                       | Click the <b>Create Project</b> link in the Quick Start section of the Getting Started page.          | The New Project link in the Getting<br>Started page allows you to create a<br>new Vivado Design Suite project.                                                    |  |
| •                       | Create a new project using the New Project Wizard with the following details:                         | By default, the Vivado IDE creates<br>the project name as <i>project_1</i> .                                                                                      |  |
|                         | <ul> <li>Project name: project_IPI</li> </ul>                                                         |                                                                                                                                                                   |  |
|                         | <ul> <li>Project location:<br/>\$TRAINING_PATH/IP_<br/>Integrator/demo/KCU105/<br/>verilog</li> </ul> |                                                                                                                                                                   |  |
|                         | <ul> <li>Select <b>Do not specify the</b></li> </ul>                                                  |                                                                                                                                                                   |  |
|                         | sources at this time.                                                                                 |                                                                                                                                                                   |  |
|                         | • Select the <b>KCU105</b> Board.                                                                     |                                                                                                                                                                   |  |
| •                       | Click <b>Create Block Design</b> under IP Integrator in the Flow Navigator.                           | <ul> <li>The IP integrator allows you to:</li> <li>Create a new block design</li> <li>Open an existing block design</li> <li>Generate the block design</li> </ul> |  |

| Action with Description |                                                                                                                                                 | Point of Emphasis and Key Takeaway |                                                                                                                                                    |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| •                       | Enter <b>subsystem_1</b> as the design name in the Create Block Design dialog box.                                                              | •                                  | <ul> <li>The canvas provides options to:</li> <li>Add IPs (Add IP) into the subsystem</li> <li>Validate the subsystem (Validate Design)</li> </ul> |
| •                       | <ul> <li>Click the Add IP link in the canvas.</li> <li>Alternatively, you can click the Add IP icon (+) from the horizontal toolbar.</li> </ul> | •                                  | This opens the IP repository of Xilinx and third-party IPs.  IPs can be searched by name via the Search field.                                     |
| •                       | Enter <b>AXI Interconnect</b> in the Search field.                                                                                              | •                                  | This adds the AXI Interconnect IP into the subsystem.                                                                                              |
| •                       | Select the <b>AXI Interconnect</b> IP from the results. Double-click the IP.                                                                    |                                    |                                                                                                                                                    |
| •                       | Similarly, add the <b>AXI Uartlite</b> IP to the block design in the same way.                                                                  | •                                  | Adding the AXI uartlite IP into the subsystem.                                                                                                     |
| •                       | Add the <b>AXI IIC</b> IP to the block design.                                                                                                  | •                                  | Adding the AXI IIC IP into the subsystem.                                                                                                          |
|                         |                                                                                                                                                 | •                                  | IP have been added to IP integrator canvas. Now, it is time to connect IP together to create a subsystem.                                          |

2

#### **Action with Description**

### **Point of Emphasis and Key Takeaway**



- Select the S00\_AXI interface in the AXI Interconnect IP.
- Right-click and select Create Interface Port.
- Click **OK** in the dialog box to make the S00\_AXI interface as an interface port.
- This is used to create ports on the interfaces, which are groupings of signals that share a common function.
  - For example, S\_AXI is an interface port on several Xilinx IP. The command gives more control in terms of specifying the interface type and the mode (master/slave).
- You specify the interface name, the vendor, library, name, and version (VLNV), as well as the mode (MASTER or SLAVE or MONITOR) in this dialog box.

| Action with Description |                                                                                                                                                                                                                                                                                                                      | Point of Emphasis and Key Takeaway |                                                                                                                                                                                                                                                                                                                                                           |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| •                       | Select the <b>ACLK</b> port in the AXI Interconnect IP. Right-click and select <b>Create Port</b> . Enter <b>100</b> in the Frequency (MHz) field of the dialog box. Click <b>OK</b> in the dialog box to make ACLK as a top-level port.                                                                             | •                                  | Create Port gives you more control in terms of specifying the input/output and the bit width and the type (clk, reset, data).  In the case of a clock, you can even specify the input frequency.                                                                                                                                                          |
| •                       | Select the <b>ARESETN</b> port in the AXI Interconnect IP. Right-click and select <b>Create Port</b> . Click <b>OK</b> in the dialog box to make ARESETN as a top-level port.  Double-click the <b>ARESETN</b> port to open the Customize Port dialog box. Select the <b>ACTIVE LOW</b> option and click <b>OK</b> . | •                                  | You can change the polarity of the reset in the Customize Port dialog box.                                                                                                                                                                                                                                                                                |
| •                       | Place the cursor on the S00_ACLK port of the AXI Interconnect block.                                                                                                                                                                                                                                                 | •                                  | <ul> <li>Making connections in IP integrator is simple.</li> <li>As you move the cursor near an interface or pin connector on an IP block, the cursor changes into a pencil.</li> <li>You can then click an interface or pin connector on an IP block, hold down the left mouse button, and then draw the connection to the destination block.</li> </ul> |

| Action with Description                                                                                                                                                                                               | Point of Emphasis and Key Takeaway                                                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Click-and-drag the cursor from S00_ACLK to ACLK.</li> <li>Make the following connections in the same way:         <ul> <li>M00_ACLK → ACLK</li> <li>M01_ACLK → ACLK</li> </ul> </li> </ul>                   | <ul> <li>As you drag the connection wire, a green check appears on the ACLK port, indicating that a valid connection can be made between these ports.</li> <li>The Vivado IP integrator highlights all possible connection point in the subsystem.</li> </ul> |
| <ul> <li>Click-and-drag the cursor from S00_ARESETN to ARESETN.</li> <li>Make the following connections in the same way:         <ul> <li>M00_ARESETN → ARESETN</li> <li>M01_ARESETN → ARESETN</li> </ul> </li> </ul> | The pencil symbol makes it easy for making connections.                                                                                                                                                                                                       |
| <ul> <li>Make the following connections between the AXI uartlite IP and AXI Interconnect IP:</li> <li>S_AXI → M00_AXI</li> <li>s_axi_aclk → ACLK</li> <li>s_axi_aresetn → ARESETN</li> </ul>                          |                                                                                                                                                                                                                                                               |
| <ul> <li>Make the following connections between the AXI IIC IP and AXI Interconnect IP:</li> <li>S_AXI → M01_AXI</li> <li>s_axi_aclk → ACLK</li> <li>s_axi_aresetn → ARESETN</li> </ul>                               |                                                                                                                                                                                                                                                               |

| Action with Description |                                                                                                                                                                                                                                                          | Point of Emphasis and Key Takeaway                                                                                                                                             |                                                                                                                                                                                    |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| •                       | Click the Run Connection  Automation link in the banner at the top of the design canvas.  Select /axi_iic_0/IIC and click OK.                                                                                                                            | <ul> <li>Run Connection Automation<br/>provides assistance in hooking<br/>interfaces and/or ports to external<br/>I/O ports.</li> </ul>                                        |                                                                                                                                                                                    |
|                         |                                                                                                                                                                                                                                                          | This makes the iic port of the AXI IIC     IP as an external port.                                                                                                             |                                                                                                                                                                                    |
| •                       | Click the Run Connection Automation link again.                                                                                                                                                                                                          | This makes the UART port of the AX uartlite IP as an external port.                                                                                                            | (I                                                                                                                                                                                 |
| •                       | Select axi_uartlite_0/UART and click OK.                                                                                                                                                                                                                 |                                                                                                                                                                                |                                                                                                                                                                                    |
| •                       | Click the <b>Validate Design</b> icon ( <b>☑</b> ) in the Diagram tab to validate the block design.                                                                                                                                                      | The Vivado IP integrator runs basic<br>design rule checks in real time as th<br>design is being put together.                                                                  |                                                                                                                                                                                    |
| •                       | Clock <b>OK</b> after validation is successful.                                                                                                                                                                                                          | Validate Design runs a comprehensive design check on the design.                                                                                                               | )                                                                                                                                                                                  |
| •                       | Select the <b>subsystem_1</b> block design in the Hierarchy tab of the Sources window.                                                                                                                                                                   | Once the block diagram is complete<br>and the design is validated, there are<br>two more steps required to                                                                     |                                                                                                                                                                                    |
| •                       | <ul> <li>Right-click and select Generate         Output Products.     </li> <li>Click Generate in the dialog box to generate the output products for the subsystem.</li> <li>Click OK after the successful generation of the output products.</li> </ul> | <ul> <li>complete the design.</li> <li>First, the output products must be generated.</li> </ul>                                                                                |                                                                                                                                                                                    |
|                         |                                                                                                                                                                                                                                                          | appropriate constraints for all the IF                                                                                                                                         | ropriate constraints for all the IP be generated and made able in the Vivado IDE Sources e. Depending upon the target uage selected during project tion, appropriate files will be |
| •                       |                                                                                                                                                                                                                                                          | will be generated and made available in the Vivado IDE Sources pane. Depending upon the target language selected during project creation, appropriate files will be generated. |                                                                                                                                                                                    |

|   | Action with Description                                                                                                                         | Po | oint of Emphasis and Key Takeaway                                                                                                            |
|---|-------------------------------------------------------------------------------------------------------------------------------------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------|
| • | Select <b>Verilog</b> as the Target language from the Settings.                                                                                 | (  | An IP integrator block diagram can<br>be integrated into a higher-level<br>design or it can be the highest level<br>in the design hierarchy. |
| • | Right-click <b>subsystem_1</b> in the Hierarchy tab of the Sources window                                                                       |    |                                                                                                                                              |
|   | and select <b>Create HDL Wrapper</b> .                                                                                                          | •  | To integrate the IP integrator design into a higher-level design, simply                                                                     |
| • | Click <b>OK</b> in the Create HDL Wrapper dialog box.                                                                                           |    | instantiate the design in the top-level HDL file.                                                                                            |
| • | Select <b>File</b> > <b>Save Block Design</b> to save the block design.                                                                         |    |                                                                                                                                              |
| • | <pre>Enter write_bd_tcl \$::env(TRAINING_PATH)/IP_ Integrator/demo/KCU105/ verilog/IPI.tcl in the Tcl Console to generate the Tcl script.</pre> | •  | The Tcl script enables designers to re-create entire block design just by running this Tcl script.                                           |
| • | Run implementation to implement the IPI subsystem.                                                                                              |    |                                                                                                                                              |
| • | Click <b>Cancel</b> in the Open Implemented Design dialog box.                                                                                  |    |                                                                                                                                              |
| • | Select <b>File</b> > <b>Exit</b> .                                                                                                              | •  | This option closes the Vivado Design<br>Suite.                                                                                               |

## **Summary**

In this demonstration, you walked through creating a simple Vivado IP integrator subsystem design by integrating some common peripherals and cores and connecting them via an AXI Interconnect block. You then created the top-level HDL wrapper for the completed subsystem design, which is later implemented in the Vivado Design Suite.

#### References:

- Supporting materials
  - Vivado Design Suite User Guide: Designing IP Subsystems Using IP Integrator (UG994)